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CREATION AND DELIVERY OF CUSTOMIZED CONTENT 

Copyright Notice and Permission 

A portion of the disclosure of this patent document may contain material that is 
subject to copyright protection. The copyright owner has no objection to the facsimile 
reproduction by anyone of the patent document or the patent disclosure, as it appears in 
the Patent and Trademark Office patent files or records, but otherwise reserves all 
copyright rights whatsoever. The following notice shall apply to this document: 
Copyright © 2000, Microsoft, Inc. 

Technical Field of the Invention 

The present invention pertains generally to computer networking, and more 
particularly to the creation and delivery of content using the Internet. 

Background of the Invention 

Electronic mail and the Internet have become increasingly common ways of 
delivering information to users throughout the world. Due to the international nature of 
the Internet, information providers have experienced a growing need to provide content 
that is interesting and understandable to diverse users from various parts of the world. 
For example, French users are likely to be more interested in information relating to 
France than in information relating to the United States. Also, they generally prefer 
information to be presented in French rather than English. The process of providing 
customized content that is both understandable and interesting to users from diverse 
locations is known as localization. 

Conventionally, localization involves predicting locations from which users are 
likely to originate and creating electronic documents, such as electronic mail messages 
and HTML pages, for each such location. For example, a set of documents is typically 
created for each country for which localization is desired. Multilingual countries, such as 
Canada, might have two or more associated sets of documents. 

Maintaining multilingual content presents a number of challenges. First, it is 
desirable to use server resources efficiently by supporting multiple languages from each 
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server. This server should also readily support the addition of new languages. Another 
challenge is the need to preserve the operability of the code underlying the content, e.g., 
HTML formatting. Because localization is often performed by parties other than the 
content provider, localized versions of content may not be coordinated with each other. 

5 As a result, integrating several localized versions of content can suffer from compatibility 
problems or other impediments. 

This challenge is further complicated by the variety of browsers and browser 
versions employed by various users around the world. Because browsers have individual 
nuances and differences in character set support (e.g., DBCS, UTF-8, Unicode), support 

10 for several different types of browsers is desirable. 

With respect to electronic mail, most conventional web systems use a plain text 
electronic mail format that does not adequately provide rich-text features, such as user- 
selectable fonts and colors. Further, the fixed portion of electronic mail messages is 
typically embedded in the code, making localization to other languages and locations 

15 difficult. 

Summary of the Invention 

According to various example implementations of the invention, there is provided 
a process for generating and delivering customized content to clients in both electronic 

20 mail and web contexts, including, but not limited to, web communities. In both of these 
contexts, customizable content is isolated from underlying code, which is used as a 
template that represents a basic document framework into which customized content is 
inserted. The content may be customized for clients of diverse language and 
geographical backgrounds in a process known as localization. Alternatively, the content 

25 may be customized for other purposes, such as promotion of specific brands of products. 

In one particular implementation, fixed and variable portions of a customizable 
Internet document are identified. The variable portion is isolated, for example, by 
extracting string literals from the document. Customized versions of the variable portion 
are stored, e.g., in a directory hierarchy sorted by country and language. When the client 

30 issues a request, a customized document is generated by combining the fixed portion and 
a selected customized version and is transmitted to the client. 
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Another implementation is a method for delivering a customized electronic mail 
message to a client. Indicators of the message type and language are received from the 
client, along with custom data used to generate the electronic mail message. Based on 
the message type and language, a selected message template is received and is combined 

5 with the custom data to generate message components, such as the sender's and 

recipient's electronic mail addresses, the subject header, and the message body of the 
electronic mail message. These components are encoded together as the customized 
electronic mail message, which is transmitted to the client. 

According to still another implementation, customized versions of a customizable 

10 document are generated by extracting a customizable portion of the localizable document, 
for example, by extracting string literals from the customizable document. Customized 
versions of the customizable portion are stored in a directory hierarchy. Each of these 
customized versions is translated to multiple encoded versions representing, e.g., 
Unicode, UTF-8, and DBCS versions of the same content. These encoded versions are 

1 5 stored in the directory hierarchy. 

Yet another implementation is directed to a method for delivering a customized 
document to a client. A fixed portion and multiple localized versions of a variable 
portion of a customizable document are stored. A client request including a DNS entry is 
received from the client. This DNS entry is detected and is used as a basis for selecting 

20 one of the customized versions to use in constructing the localized document. The 
customized document is generated by combining the fixed portion with the selected 
customized version and is delivered to the client. 

Still other implementations include computer-readable media and apparatuses for 
performing these methods. The above summary of the present invention is not intended 

25 to describe every implementation of the present invention. The figures and the detailed 
description that follow more particularly exemplify these implementations. 



Brief Description of the Drawings 

Figure 1 illustrates a simplified overview of an example embodiment of a 
30 computing environment for the present invention. 

Figure 2 illustrates an example system architecture for delivering localized 
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and customized electronic mail to clients, according to an example 
embodiment of the present invention, 
is a flowchart depicting an example method for delivering 
localized and customized electronic mail, according to 
still another embodiment of the present invention, 
is a flowchart illustrating an example method for creating and 
storing localized content of a web site, according to still another 
embodiment of the present invention. 

depicts an example directory hierarchy for use with the methods 
illustrated in Figures 4 and 6. 

is a flowchart illustrating an example method for delivering 
localized content to clients, according to yet another embodiment 
of the present invention. 

15 Detailed Description of the Invention 

In the following detailed description of the preferred embodiments, reference is 
made to the accompanying drawings that form a part hereof, and in which are shown by 
way of illustration specific embodiments in which the invention may be practiced. It is 
understood that other embodiments may be utilized and structural changes may be made 
20 without departing from the scope of the present invention. 

Hardware and Operating Environment 
Figure 1 illustrates a hardware and operating environment in conjunction with 
which embodiments of the invention may be practiced. The description of Figure 1 is 

25 intended to provide a brief, general description of suitable computer hardware and a 
suitable computing environment with which the invention may be implemented. 
Although not required, the invention is described in the general context of computer- 
executable instructions, such as program modules, being executed by a computer, such as 
a personal computer (PC). This is one embodiment of many different computer 

30 configurations, some including specialized hardware circuits to analyze performance, that 
may be used to implement the present invention. Generally, program modules include 
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routines, programs, objects, components, data structures, etc. that perform particular tasks 
or implement particular abstract data types. 

Moreover, those skilled in the art will appreciate that the invention may be 
practiced with other computer-system configurations, including hand-held devices, 

5 multiprocessor systems, microprocessor-based or programmable consumer electronics, 
network personal computers ("PCs"), minicomputers, mainframe computers, and the like. 
The invention may also be practiced in distributed computing environments where tasks 
are performed by remote processing devices linked through a communications network. 
In a distributed computing environment, program modules may be located in both local 

10 and remote memory storage devices. 

Figure 1 shows a computer arrangement implemented as a general-purpose 
computing or information-handling system 80. This embodiment includes a general 
purpose computing device such as personal computer (PC) 20, that includes processing 
unit 21, a system memory 22, and a system bus 23 that operatively couples the system 

15 memory 22 and other system components to processing unit 21 . There may be only one 
or there may be more than one processing unit 21, such that the processor computer 20 
comprises a single central-processing unit (CPU), or a plurality of processing units, 
commonly referred to as a parallel processing environment. The computer 20 may be a 
conventional computer, a distributed computer, or any other type of computer; the 

20 invention is not so limited. 

In other embodiments other configurations are used in PC 20. System bus 23 may 
be any of several types, including a memory bus or memory controller, a peripheral bus, 
and a local bus, and may use any of a variety of bus architectures. The system memory 
22 may also be referred to as simply the memory, and it includes read-only memory 

25 (ROM) 24 and random-access memory (RAM) 25. A basic input/output system (BIOS) 
26, stored in ROM 24, contains the basic routines that transfer information between 
components of personal computer 20. BIOS 26 also contains start-up routines for the 
system. 

Personal computer 20 further includes hard disk drive 27 having one or more 
30 magnetic hard disks (not shown) onto which data is stored and retrieved for reading from 
and writing to hard-disk-drive interface 32, magnetic disk drive 28 for reading from and 
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writing to a removable magnetic disk 29, and optical disk drive 30 for reading from 
and/or writing to a removable optical disk 31 such as a CD-ROM, DVD or other optical 
medium. Hard disk drive 27, magnetic disk drive 28, and optical disk drive 30 are 
connected to system bus 23 by a hard-disk drive interface 32, a magnetic-disk drive 

5 interface 33, and an optical-drive interface 34, respectively. The drives 27, 28, and 30 
and their associated computer-readable media 29, 31 provide nonvolatile storage of 
computer-readable instructions, data structures, program modules and other data for 
personal computer 20. Although the exemplary environment described herein employs a 
hard disk, a removable magnetic disk 29 and a removable optical disk 31, those skilled in 

10 the art will appreciate that other types of computer-readable media which can store data 
accessible by a computer may also be used in the exemplary operating environment. 
Such media may include magnetic tape cassettes, flash-memory cards, digital video disks 
(DVD), Bernoulli cartridges, RAMs, ROMs, and the like. 

In various embodiments, program modules are stored on the hard disk drive 27, 

15 magnetic disk 29, optical disk 3 1 , ROM 24 and/or RAM 25 and may be moved among 
these devices, e.g., from hard disk drive 27 to RAM 25. Program modules include 
operating system 35, one or more application programs 36, other program modules 37, 
and/or program data 38. A user may enter commands and information into personal 
computer 20 through input devices such as a keyboard 40 and a pointing device 42. 

20 Other input devices (not shown) for various embodiments include one or more devices 
selected from a microphone, joystick, game pad, satellite dish, scanner, or the like. These 
and other input devices are often connected to the processing unit 21 through a serial-port 
interface 46 coupled to system bus 23, but in other embodiments they are connected 
through other interfaces not shown in Figure 1, such as a parallel port, a game port, or a 

25 universal serial bus (USB) interface. A monitor 47 or other display device also connects 
to system bus 23 via an interface such as a video adapter 48. In some embodiments, one 
or more speakers 57 or other audio output transducers are driven by sound adapter 56 
connected to system bus 23. In some embodiments, in addition to the monitor 47, system 
80 includes other peripheral output devices (not shown) such as a printer or the like. 

30 In some embodiments, personal computer 20 operates in a networked 

environment using logical connections to one or more remote computers such as remote 
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computer 49. Remote computer 49 may be another personal computer, a server, a router, 
a network PC, a peer device, or other common network node. Remote computer 49 
typically includes many or all of the components described above in connection with 
personal computer 20; however, only a storage device 50 is illustrated in Figure 1. The 
5 logical connections depicted in Figure 1 include local-area network (LAN) 51 and a 
wide-area network (WAN) 52, both of which are shown connecting PC 20 to remote 
computer 49; typical embodiments would only include one or the other. Such networking 
environments are commonplace in offices, enterprise-wide computer networks, Intranets 
and the Internet. 

10 When placed in a LAN networking environment, PC 20 connects to local network 

51 through a network interface or adapter 53. When used in a WAN networking 
environment such as the Internet, PC 20 typically includes modem 54 or other means for 
establishing communications over network 52. Modem 54 may be internal or external to 
PC 20 and connects to system bus 23 via serial-port interface 46 in the embodiment 

15 shown. In a networked environment, program modules depicted as residing within PC 20 
or portions thereof may be stored in remote-storage device 50. Of course, the network 
connections shown are illustrative, and other means of establishing a communications 
link between the computers may be substituted. 

Software may be designed using many different methods, including object- 

20 oriented programming methods. C++ and Java are two examples of common object- 
oriented computer programming languages that provide functionality associated with 
object-oriented programming. Object-oriented programming methods provide a means to 
encapsulate data members (variables) and member functions (methods) that operate on 
that data into a single entity called a class. Object-oriented programming methods also 

25 provide a means to create new classes based on existing classes. 

An object is an instance of a class. The data members of an object are attributes 
that are stored inside the computer memory, and the methods are executable computer 
code that act upon this data, along with potentially providing other services. The notion 
of an object is exploited in the present invention in that certain aspects of the invention 

30 are implemented as objects in some embodiments. 
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An interface is a group of related functions that are organized into a named unit. 
Some identifier may uniquely identify each interface. Interfaces have no instantiation; 
that is, an interface is a definition only without the executable code needed to implement 
the methods that are specified by the interface. An object may support an interface by 
5 providing executable code for the methods specified by the interface. The executable 
code supplied by the object must comply with the definitions specified by the interface. 
The object may also provide additional methods. Those skilled in the art will recognize 
that interfaces are not limited to use in or by an object-oriented programming 
environment. 

10 Example Embodiments of the Invention 

According to one example embodiment of the present invention, customized 
content is delivered to a user over a computer network, for example, via either Hypertext 
Transfer Protocol (HTTP) or electronic mail. For discussion purposes only, it is assumed 
that the content is to be localized, that is, customized for users of diverse language and/or 

15 geographical backgrounds. Localizable content - content that lends itself to 

customization for a particular user based on the language and/or location of the user - is 
separated from the underlying code used to format the document. This code defines a 
basic document framework into which localized content is inserted. By separating the 
content and code, a uniform document format is realized that facilitates creation of 

20 localized content by third parties, which are freed from concerns over compatibility 
issues as they no longer need to create code. Further, expandability to other browsers, 
languages and geographical regions is enhanced. While the present discussion is 
particularly focused on localization, it is to be understood that these techniques can also 
be used to create and deliver content that is customized in other ways, such as 

25 customization for promotion of specific products. 

In one particular implementation, a rich text HTML-formatted electronic mail 
message is automatically generated with customizable and localizable content using a 
template file. The template file represents the layout of the electronic mail message to be 
generated, which includes a fixed portion and a customizable portion. The fixed portion 

30 contains, for example, text that does not vary between individual messages. By contrast, 
the customizable portion contains information that is specific to each individual message. 
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For example, the customizable portion might be generated based on information from an 
external database. The fixed and customizable portions are combined to form the 
electronic mail message, which is delivered to the user. 

A message queue receives electronic mail generation jobs from one or more client 

5 servers and sends the jobs to a notification server. The notification server, in turn, 
processes the electronic mail generation jobs into their final multipart Multipurpose 
Internet Mail Extensions (MIME) encoded format, which can be sent using conventional 
outbound SMTP servers. The notification server manages the load distribution and 
failover across the outbound SMTP servers to make efficient use of computing resources. 

10 The SMTP servers encode electronic mail messages into a conventional multipart MIME 
format that supports the inclusion of plain text and HTML versions of the content in a 
single electronic mail message. Thus, rich text features are available to users of 
electronic mail software that supports rich text, while users whose software does not 
support rich text can view the plain text version of the message. Further, non-English 

15 and extended characters can be encoded in the message in a format that can be sent using 
the SMTP protocol. 

In a Web environment implementation, localized content is generated and is 
delivered to a client using HTTP. A localization tool is used to isolate localizable content 
from the code. The localizable content can be isolated in any of a number of ways, such 

20 as by extracting string literals from the code and storing them. The localized content and 
code are stored in a directory using a hierarchical structure that organizes the code by 
language and geographical location. With the content and the code separated, third party 
developers can localize or otherwise modify the content without affecting the code. This 
technique also provides for expandability, as adding new localized content is simply a 

25 matter of creating a new directory in the hierarchy and populating the new directory with 
localized content. A single Web server hosts multiple sites, each with localized content. 
Each site has a unique domain name server (DNS) entry mapped to an IP address. When 
a client request is made against one of the DNS entries, the request is directed to the 
corresponding IP address. The original DNS entry, however, is preserved in the request. 

30 The server code uses the DNS entry to determine which site's content to use in the 
response. The server then delivers the appropriate localized content to the client. 
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Referring again to the drawings, Figure 2 depicts an example system architecture 
200 for delivering localized and customized electronic mail to clients. Figure 3 is a flow 
chart depicting an example process 300 followed by the system architecture illustrated in 
Figure 2. A client web server 202 initiates the mail creation process at the request of the 

5 user. The client web server 202 uses a mail creation Application Program Interface (API) 
204, an object that receives the data required to build the electronic mail, as illustrated at 
block 302 of Figure 3. For example, the mail creation API 204 receives such data as the 
type of mail to be created, the content of the mail, the recipient's electronic mail address, 
and custom data in the UTF-8 format. The mail creation API 204 also receives the 

10 desired language and codepage with which the message is to be created. In addition, at 
block 304, the mail creation API 204 selects and receives one or more message templates 
stored in the client web server 202 based on, for example, the type and language of the 
message. These message templates are stored in the client web server 202 according to a 
directory hierarchy, categorized by codepage and language. For example, one 

15 subdirectory in the hierarchy might store French language message templates for use with 
codepage 1252, In a particular implementation, the message templates are further 
categorized by country, e.g., American English as distinct from British English. At block 
306, the UTF-8 formatted custom data is converted to the correct double byte character 
set (DBCS) using the specified codepage to facilitate sending the message using a single 

20 codepage. 

After receiving a message template and the data for creating the message, the mail 
creation API 204 merges the data with the message template, as depicted at block 308. 
As a result, message components, such as the sender's and recipient's electronic mail 
addresses, the subject header, and the message body, are generated. Next, at block 310, 

25 the mail creation API 204 determines whether the user wishes to preview the electronic 
mail message. If so, as illustrated at block 312, the message components are returned to 
the client application so the user can see how the message will appear to the recipient. If 
the user is not satisfied with the message, as depicted at block 314, flow returns to block 
302, at which the user edits the message and the system receives additional data for 

30 building the message. If the user does not wish to preview the message, the message 
components are instead packaged into a format for output to a message queue 208. The 
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message components are then transported to a notification server 210 via the message 
queue 208, as illustrated at block 316. 

Next, at block 318, the notification server 210 receives the merged information 
from the message queue 208. At block 320, the notification server 210 determines 
5 whether the message is addressed to a distribution list. If so, the notification server 210 
references an SQL server 214 to obtain an expansion list specifying the individual 
addresses constituting the distribution list, as depicted at block 322. The notification 
server 210 then creates a distinct outbound MIME encoded message for each address in 
the distribution list. Alternatively, the notification server 210 can include a distribution 
10 list of multiple addresses in a single message, e.g., by using a Bcc: header with an address 
list. 

At block 324, the notification server 210 then encodes the message components as 
a multipart MIME encoded message using, for example, a MIME OLE library 212, to 
encode extended characters and DBCS characters according to Internet mail conventions. 
15 The multipart MIME format supports the inclusion of both plain text and HTML versions 
of the mail in a single outbound message. Further, the format supports encoding non- 
English and extended characters into a format that can be transmitted using the SMTP 
mail protocol. 

As depicted at block 326, the notification server 210 then outputs the MIME 
20 encoded message or messages to one of several STMP outbound servers 216, which 

delivers the message to its intended recipient or recipients. To facilitate efficient use of 
the SMTP outbound servers 216, the notification server 210 uses a round-robin technique 
to alternate among the SMTP outbound servers 216 and thus manage the load distribution 
among them. This round-robin technique also helps the notification server 210 manage 
25 failover by ensuring that messages are sent only to healthy SMTP outbound servers 216. 

It should be noted that Figure 2 depicts two client web servers 202 associated with 
the notification server 210, each using a distinct mail creation API 204. The notification 
server 210 can, however, serve more or fewer client web servers 202. Indeed, a typical 
network configuration would have far more than two client web servers 202 associated 
30 with the notification server 210, and could also have multiple notification servers 210. In 
this respect, Figure 2 is simplified. 
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By selecting a message template based on the recipient's location and/or 
language, the system can generate localized or customized electronic mail easily. 
Further, MIME encoding enables the system to send both rich text and plain text versions 
of content in a single electronic mail message. Accordingly, the receiving mail client can 

5 display the best or richest version of the message supported by the mail client. 

In another particular embodiment, a single server hosts a Web environment or 
community that can deliver localized content, e.g., HTML pages, to users from diverse 
locations using a variety of languages. Figure 4 depicts an example process 400 for 
generating localized content for delivery to a diverse user base. First, at block 402, 

10 localizable content is isolated from the underlying code by extracting the string literals 
from the code and storing the string literals as symbols whose names follow a prescribed 
convention. Next, at block 404, the localizable content is exported to a localizer or 
localizers for translation to localized content in one or more alternate languages. The 
localized content is received from the localizer or localizers at block 406, and is stored in 

1 5 a directory hierarchy at block 408. 

Figure 5 depicts an example directory hierarchy 500 that can be used to store the 
localized content. In this hierarchy, a directory 502 serves as a base directory under 
which all other directories in the hierarchy are subordinate. Directly under the directory 
502 are one or more site directories 504, each of which stores the content for a particular 

20 site hosted by the web server. Each site directory 504 has a name that follows a 
convention based on the country and language corresponding site. Under the site 
directories 504 are format directories 506, which store the various versions of content 
within a single country/language group. For example, format directories 506 can be 
created to store DBCS, Unicode, and UTF-8 versions of the same content, as well as the 

25 unconverted localized content itself. Within each format directory 506, one or more 
document directories 508 may be present; these store different documents, such as help 
documents. 

Referring again to Figure 4, after the localized content is stored in the directory 
hierarchy, the system automatically converts the content to one or more versions, e.g., 
30 DBCS, Unicode, and UTF-8 versions, as depicted at block 410. In a particular 

implementation, each localizer is given the DBCS English version of the content. Each 
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localizer then returns a DBCS version of the content, localized for a specific site 
corresponding to a country-language combination. The system then automatically 
converts the DBCS version of each translation into UTF-8 and Unicode versions. Thus, 
localizers only need to translate the content once and to a single character encoding 
5 scheme. Finally, at block 412, these versions are stored in the appropriate format 
directories 506. 

Once the localized content has been stored in the directory hierarchy 500, it can 
be delivered to clients from diverse locations around the world. Figure 6 depicts an 
example process 600 for delivering localized content to clients. At a block 602, the web 

10 server receives a client request from a client server. From this client request, the web 
server detects the domain name server (DNS) entry, as depicted at block 604. In this 
implementation, DNS entries are associated with a single IP address in a many-to-one 
relationship. That is, several DNS entries, e.g., communities.msn.com, communities.ja- 
jp.msn.com, communities.de-de.msn.com, etc., are registered and associated with a single 

15 IP address, but not necessarily to a single server. Multiple servers can share a single IP 
address by using a conventional hardware or software tool known as a virtual EP. Client 
requests to a DNS entry, such as communities.msn.com, are mapped to the virtual IP and 
passed to a specific server by the virtual IP in what is known as a round-robin technique 
of handling requests. With multiple DNS entries associated with a single IP address that 

20 may be shared between multiple servers, server configuration is simplified, and reliance 
on the web server's support of virtual web sites is eliminated. Because several DNS 
entries are associated with a single IP address, client requests containing any of these 
DNS entries will be directed to the server associated with the IP address. The DNS entry, 
however, is preserved in the request and is detected by the web server. The web server 

25 detects the DNS entry at the beginning of the client request, and all code executed in 
processing the request uses the results of this detection. 

Next, at block 606, the web server maps the DNS entry to a particular 
language/country site using a configuration table. For example, the web server maps the 
DNS entry communities.ja-jp.msn.com to the Japanese language/Japanese content site. 

30 The client's browser is directed to this site at block 608, and localized content is 
delivered from this site to the client's browser at block 610. 
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With all localized content and code stored in the directory hierarchy 500 
according to a prescribed convention, a number of benefits are realized. For example, 
adding a new site and a new site's localized content to the web server is simply a matter 
of adding the site's directory to the directory hierarchy 500, adding the content under the 

5 site's directory, and sharing the code base. Reorganization is not necessary when content 
is transferred between the directory hierarchy 500 and a production server. Further, 
support for various browsers is facilitated, as the task is merely a matter of mapping each 
browser to an appropriate character encoding {e.g., Unicode, UTF-8, DBCS) and 
delivering the correct combination of content and code to the browser. Because all sites 

10 share the same file hierarchy under their site directory, only the top level site decision of 
which content/code combination to deliver needs to be made. The web server makes this 
decision at the time of the client request based on HTTP header information. 

While the embodiments of the invention have been described with specific focus 
on their embodiment in a software implementation, the invention as described above is 

15 not limited to software embodiments. For example, the invention may be implemented in 
whole or in part in hardware, firmware, software, or any combination thereof. The 
software of the invention may be embodied in various forms such as a computer program 
encoded in a machine-readable medium, such as a CD-ROM, magnetic medium, ROM or 
RAM, or in an electronic signal. Further, as used in the claims herein, the term "module" 

20 shall mean any hardware or software component, or any combination thereof. 
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What is claimed is: 



1 . A computer-implemented method for delivering a customized Internet 
5 document to a client, the method comprising: 

identifying a fixed portion and a variable portion of a customizable document; 

isolating the variable portion of the customizable document; 

storing a plurality of customized versions of the variable portion of the 
customizable document; 
10 in response to a request issued by the client, selecting at least one of the plurality 

of customized versions as a function of at least one of a language and a location 
attributable to the client; 

generating the customized Internet document by combining the fixed portion and 
the selected at least one of the plurality of customized versions; and 
15 transmitting the customized Internet document to the client. 

2. The method of claim 1, wherein the customized document is HTML 
encoded. 

20 3. A computer-implemented method for delivering a customized electronic 

mail message to a client, the method comprising: 

identifying a fixed portion and a variable portion of a customizable document; 
isolating the variable portion of the customizable document; 
storing a plurality of customized versions of the variable portion of the 
25 customizable document; 

in response to a request issued by the client, generating a plurality of message 
components as a function of the fixed portion and at least one selected customized 
version; 

encoding the plurality of message components as the customized electronic mail 
30 message; and 

transmitting the customized electronic mail message to the client. 
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4. The method of claim 3, further comprising receiving at least one of a 
message type indicator, a message language indicator, a recipient electronic mail address, 
and custom data in a UTF-8 format. 

5 

5 . The method of claim 4, further comprising: 

storing a plurality of fixed portions of a plurality of documents; 

selecting one of the plurality of fixed portions as a function of the message type 
indicator and the message language indicator; and 
10 generating the customized document by combining the selected fixed portion with 

the selected customized version. 

6. The method of claim 4, further comprising converting the custom data into 
a DBCS format. 

15 

7. The method of claim 3, wherein the plurality of message components 
comprises at least one of a sender electronic mail address, a recipient electronic mail 
address, a subject header, and a message body. 

20 8. The method of claim 7, further comprising, in response to identifying the 

recipient electronic mail address as a distribution list, 

determining a plurality of electronic mail addresses constituting the distribution 
list; and 

generating a distinct electronic mail message for each of the determined electronic 
25 mail addresses. 

9. The method of claim 7, further comprising, in response to identifying the 
recipient electronic mail address as a distribution list, 

determining a plurality of electronic mail addresses constituting the distribution 
30 list; and 
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generating an electronic mail message having the plurality of electronic mail 
addresses associated therewith. 

1 0. The method of claim 7, further comprising encoding the plurality of 
5 message components using a MIME encoding technique. 

1 1 . The method of claim 1 0, further comprising encoding the plurality of 
message components by referencing a MIME OLE library. 

10 12. The method of claim 10, further comprising: 

generating plain text and rich text versions of the message components; and 
encoding the plain text and rich text versions in the electronic mail message. 

1 3 . The method of claim 3, further comprising selecting an outbound server 
15 for delivering the customized electronic mail message according to a round-robin 

technique. 

14, A computer-implemented method for delivering a customized World Wide 
Web (WWW) page to a client, the method comprising: 

20 identifying a fixed portion and a variable portion of a customizable WWW page; 

isolating the variable portion of the customizable WWW page; 
storing a plurality of customized versions of the variable portion of the 
customizable WWW page in a directory hierarchy as a function of one or more 
characteristics of the customized versions; 
25 in response to a request issued by the client, generating the customized WWW 

page by combining the fixed portion and the selected at least one of the plurality of 
customized versions; and 

transmitting the customized WWW page to the client. 

30 15. The method of claim 14, wherein isolating the variable portion of the 

customizable WWW page comprises: 
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extracting a plurality of string literals from the customizable WWW page; and 
storing the string literals as symbols. 

16. The method of claim 14, wherein the customized versions are 
5 characterized by at least one of a language and a location. 

17. The method of claim 16, further comprising: 

generating a plurality of encoded versions of each customized version, wherein 
the encoded versions represent DBCS, Unicode, and UTF-8 versions of a customized 
10 version; and 

storing the encoded versions in distinct subdirectories within the directory 
hierarchy. 

18. The method of claim 14, further comprising receiving a client request 
15 including a DNS entry from the client. 

1 9. The method of claim 1 8, further comprising: 
detecting the DNS entry; and 

selecting one of the customized versions of the variable portion as a function of 
20 the DNS entry. 

20. A computer-implemented method for delivering a customized electronic 
mail message to a client, the method comprising: 

receiving a message type indicator, a message language indicator, and custom 
25 data from the client; 

receiving a message template selected as a function of the message type indicator 
and the message language indicator; 

generating a plurality of message components by combining the message template 
with the custom data; 

30 encoding the message components as the customized electronic mail message; 

and 
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transmitting the customized electronic mail message to the client. 



21 . The method of claim 20, wherein the custom data is received in a UTF-8 
format, further comprising converting the custom data to a DBCS format before 

5 combining the custom data with the message template. 

22. The method of claim 20, further comprising displaying the customized 
electronic mail message before transmitting the customized electronic mail message to 
the client. 

0 

23. The method of claim 20, wherein the plurality of message components 
comprises at least one of a sender electronic mail address, a recipient electronic mail 
address, a subject header, and a message body. 



15 24. The method of claim 23, further comprising, in response to identifying the 

recipient electronic mail address as a distribution list, 

determining a plurality of electronic mail addresses constituting the distribution 
list; and 

generating a distinct electronic mail message for each of the determined electronic 
20 mail addresses. 



25. The method of claim 20, wherein the plurality of message components are 
encoded using a MIME encoding technique. 

25 26. The method of claim 25, further comprising encoding the plurality of 

message components by referencing a MIME OLE library. 



27. The method of claim 25, further comprising: 
generating a plain text version and a rich text version of the customized 
30 document; and 

encoding the plain text and rich text versions in the electronic mail message. 
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28. The method of claim 20, further comprising selecting an outbound server 
for delivering the electronic mail message according to a round-robin technique. 

29. A computer-implemented method for generating localized versions of a 
localizable Internet document for delivery to a client, the method comprising: 

extracting a localizable portion of the localizable Internet document; 
storing localized versions of the localizable portion in a directory hierarchy; 
translating each localized version to a plurality of encoded versions; and 
storing the encoded versions in the directory hierarchy. 

30. The method of claim 29, wherein extracting the localizable portion of the 
localizable Internet document comprises: 

extracting a plurality of string literals from the localizable document; and 
storing the string literals as symbols. 

3 1 . The method of claim 29, wherein the encoded versions represent DBCS, 
Unicode, and UTF-8 versions of the corresponding localized version. 

32. A computer-implemented method for delivering a localized document to a 
client, the method comprising: 

storing a fixed portion of a localizable document and a plurality of localized 
versions of a variable portion of the localizable document; 

receiving a client request from the client, the client request including a DNS 

entry; 

detecting the DNS entry; and 

selecting one of the localized versions as a function of the DNS entry; 
generating the localized document by combining the fixed portion with the 
selected localized version; and 

delivering the localized document to the client. 

20 



33. A computer arrangement, comprising : 

a client web server configured to store a plurality of message templates and to 
combine a selected one of the message templates with custom data to create a plurality of 
message components; 

5 a notification server configured to receive the message components from the 

client web server and to generate an electronic mail message as a function of the message 
components; and 

a outbound server configured to receive the electronic mail message from the 
notification server and to transmit the electronic mail message to a recipient. 

10 

34. The computer arrangement of claim 33, wherein the notification server is 
further configured to expand a distribution list associated with the message components 
into a plurality of constituent recipient electronic mail addresses and to generate a distinct 
electronic mail message for each constituent recipient electronic mail address. 

15 

35. The computer arrangement of claim 33, wherein the notification server is 
further configured to expand a distribution list associated with the message components 
into a plurality of constituent recipient electronic mail addresses and to generate an 
electronic mail message having the plurality of electronic mail addresses associated 

20 therewith. 

36. The computer arrangement of claim 33, further comprising a plurality of 
outbound servers, wherein the notification server is further configured to select one of the 
plurality of outbound servers to transmit the electronic mail message according to a 

25 round-robin technique. 

37. A computer-readable medium having computer-executable instructions 

for: 

identifying a fixed portion and a variable portion of a customizable Internet 
30 document; 

isolating the variable portion of the customizable Internet document; 
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storing a plurality of customized versions of the variable portion of the 
customizable Internet document; 

in response to a request issued by the client, selecting at least one of the plurality 
of customized versions as a function of at least one of a language and a location 
5 attributable to the client; 

generating a customized Internet document by combining the fixed portion and 
the selected at least one of the customized versions; and 

transmitting the customized Internet document to a client, 

10 38. The computer-readable medium of claim 37, wherein the customized 

document is HTML encoded. 

39. A computer-readable medium having computer-executable instructions 

for: 

15 identifying a fixed portion and a variable portion of a customizable document; 

isolating the variable portion of the customizable document; 
storing a plurality of customized versions of the variable portion of the 
customizable document; 

in response to a request issued by a client, generating a plurality of message 
20 components as a function of the fixed portion and at least one selected customized 
version; 

encoding the plurality of message components as the customized electronic mail 
message; and 

transmitting the customized electronic mail message to the client. 

25 

40, The computer-readable medium of claim 39, having further computer- 
executable instructions for receiving at least one of a message type indicator, a message 
language indicator, a recipient electronic mail address, and custom data in a UTF-8 
format. 
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41 . The computer-readable medium of claim 40, having further computer- 
executable instructions for: 

storing a plurality of fixed portions of a plurality of documents; 
selecting one of the plurality of fixed portions as a function of the message type 
5 indicator and the message language indicator; and 

generating the customized document by combining the selected fixed portion with 
the selected customized version. 

42. The computer-readable medium of claim 40, having further computer- 
10 executable instructions for converting the custom data into a DBCS format. 

43 . The computer-readable medium of claim 39, having further computer- 
executable instructions for: 

generating a plurality of message components as a function of the fixed portion 
15 and the selected customized version; and 

encoding the plurality of message components as an electronic mail message. 

44. The computer-readable medium of claim 43, wherein the plurality of 
message components comprises at least one of a sender electronic mail address, a 

20 recipient electronic mail address, a subject header, and a message body. 

45. The computer-readable medium of claim 44, having further computer- 
executable instructions for, in response to identifying the recipient electronic mail address 
as a distribution list, 

25 determining a plurality of electronic mail addresses constituting the distribution 

list; and 

generating a distinct electronic mail message for each of the determined electronic 
mail addresses. 
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46. The computer-readable medium of claim 44, having farther computer- 
executable instructions for, in response to identifying the recipient electronic mail address 
as a distribution list, 

determining a plurality of electronic mail addresses constituting the distribution 

list; and 

generating an electronic mail message having the plurality of electronic mail 
addresses associated therewith. 

47. The computer-readable medium of claim 43, having further computer- 
executable instructions for encoding the plurality of message components using a MIME 
encoding technique. 

48. The computer-readable medium of claim 47, having further computer- 
executable instructions for encoding the plurality of message components by referencing 
a MIME OLE library. 

49. The computer-readable medium of claim 47, having further computer- 
executable instructions for: 

generating a plain text version and a rich text version of the customized 

document; and 

encoding the plain text and rich text versions in the electronic mail message. 

50. The computer-readable medium of claim 40, having further computer- 
executable instructions for selecting an outbound server for delivering the electronic mail 
message according to a round-robin technique. 

51. A computer-readable medium having computer-executable instructions 

for: 

identifying a fixed portion and a variable portion of a customizable World Wide 

Web (WWW) page; 

isolating the variable portion of the customizable WWW page; 
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storing a plurality of customized versions of the variable portion of the 
customizable WWW page in a directory hierarchy as a function of one or more 
characteristics of the customized versions; 

in response to a request issued by a client, generating the customized WWW page 
5 by combining the fixed portion and the selected at least one of the plurality of customized 
versions; and 

transmitting the customized WWW page to the client. 

52. The computer-readable medium of claim 5 1 , having further computer- 
10 executable instructions for: 

extracting a plurality of string literals from the customizable document; and 
storing the string literals as symbols. 



53. The computer-readable medium of claim 5 1, wherein the plurality of 
15 customized versions of the variable portion of the customizable document are stored in a 
directory hierarchy. 



54. The computer-readable medium of claim 53, having further computer- 
executable instructions for: 
20 generating a plurality of encoded versions of each customized version, wherein 

the encoded versions represent DBCS, Unicode, and UTF-8 versions of a customized 
version; and 

storing the encoded versions in the directory hierarchy. 



25 55 . The computer-readable medium of claim 5 1 , having further computer- 

executable instructions for receiving a client request from the client, the client request 
including a DNS entry. 

56. The computer-readable medium of claim 55, having further computer- 
30 executable instructions for: 

detecting the DNS entry; and 
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selecting one of the customized versions of the variable portion as a function of 
the DNS entry. 

57. A computer-readable medium having computer-executable instructions 

for: 

receiving a message type indicator, a message language indicator, and custom 
data from a client; 

receiving a message template selected as a function of the message type indicator 
and the message language indicator; 

generating a plurality of message components by combining the message template 
with the custom data; 

encoding the message components as a customized electronic mail message; and 

transmitting the customized electronic mail message to the client. 

58. The computer-readable medium of claim 57, wherein the custom data is 
received in a UTF-8 format, further comprising converting the custom data to a DBCS 
format before combining the custom data with the message template. 

59. The computer-readable medium of claim 57, having farther computer- 
executable instructions for displaying the customized electronic mail message before 
transmitting the customized electronic mail message to the client. 

60. The computer-readable medium of claim 57, wherein the plurality of 
message components comprises at least one of a sender electronic mail address, a 
recipient electronic mail address, a subject header, and a message body. 

6 1 . The computer-readable medium of claim 60, having further computer- 
executable instructions for, in response to identifying the recipient electronic mail address 
as a distribution list, 

determining a plurality of electronic mail addresses constituting the distribution 

list; and 
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generating a distinct electronic mail message for each of the determined electronic 
mail addresses. 

62. The computer-readable medium of claim 60, having further computer- 

5 executable instructions for, in response to identifying the recipient electronic mail address 
as a distribution list, 

determining a plurality of electronic mail addresses constituting the distribution 

list; and 

generating an electronic mail message having the plurality of electronic mail 
10 addresses associated therewith. 

63 . The computer-readable medium of claim 57, wherein the plurality of 
message components are encoded using a MIME encoding technique. 

15 64. The computer-readable medium of claim 57, having further computer- 

executable instructions for encoding the plurality of message components by referencing 
a MIME OLE library. 

65. The computer-readable medium of claim 57, having further computer- 
20 executable instructions for: 

generating a plain text version and a rich text version of a customized document; 

and 

encoding the plain text and rich text versions in the electronic mail message. 

25 66. The computer-readable medium of claim 57, having further computer- 

executable instructions for selecting an outbound server for delivering the electronic mail 
message according to a round-robin technique. 

67. A computer-readable medium having computer-executable instructions 

30 for: 

extracting a localizable portion of a localizable Internet document; 
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storing localized versions of the localizable portion in a directory hierarchy; 
translating each localized version to a plurality of encoded versions; and 
storing the encoded versions in the directory hierarchy. 

68. The computer-readable medium of claim 67, wherein extracting the 
localizable portion of the localizable document comprises: 

extracting a plurality of string literals from the localizable document; and 
storing the string literals as symbols. 

69. The computer-readable medium of claim 67, wherein the encoded versions 
represent DBCS, Unicode, and UTF-8 versions of the corresponding localized version. 

70. A computer-readable medium having computer-executable instructions 

for: 

storing a fixed portion of a localizable document and a plurality of localized 
versions of a variable portion of the localizable document; 

receiving a client request from a client, the client request including a DNS entry; 
detecting the DNS entry; and 

selecting one of the localized versions as a function of the DNS entry; 
generating a localized document by combining the fixed portion with the selected 
localized version; and 

delivering the localized document to the client. 

71. A computer arrangement configured to execute computer-executable 
instructions for: 

identifying a fixed portion and a variable portion of a customizable document; 
isolating the variable portion of the customizable document; 
storing a plurality of customized versions of the variable portion of the 
customizable document; 
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in response to a request issued by a client, selecting at least one of the plurality of 
customized versions as a function of at least one of a language and a location attributable 
to the client; 

generating the customized Internet document by combining the fixed portion and 
5 the selected at least one of the plurality of customized versions; and 
transmitting the customized Internet document to the client. 

72. The computer arrangement of claim 7 1 , wherein the customized document 
is HTML encoded. 

10 

73 . A computer arrangement configured to execute computer-executable 
instructions for: 

identifying a fixed portion and a variable portion of a customizable document; 

isolating the variable portion of the customizable document; 
1 5 storing a plurality of customized versions of the variable portion of the 

customizable document; 

in response to a request issued by a client, generating a plurality of message 
components as a function of the fixed portion and at least one selected customized 
version; 

20 encoding the plurality of message components as the customized electronic mail 

message; and 

transmitting the customized electronic mail message to the client. 

74. The computer arrangement of claim 73 , further configured to execute 

25 computer-executable instructions for receiving at least one of a message type indicator, a 
message language indicator, a recipient electronic mail address, and custom data in a 
UTF-8 format. 

75. The computer arrangement of claim 74, further configured to execute 
30 computer-executable instructions for: 

storing a plurality of fixed portions of a plurality of documents; 
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selecting one of the plurality of fixed portions as a function of the message type 
indicator and the message language indicator; and 

generating the customized document by combining the selected fixed portion with 
the selected customized version. 

76. The computer arrangement of claim 74, further configured to execute 
computer-executable instructions for converting the custom data into a DBCS format. 

77. The computer arrangement of claim 73, further configured to execute 
computer-executable instructions for: 

generating a plurality of message components as a function of the fixed portion 
and the selected customized version; and 

encoding the plurality of message components as an electronic mail message. 

78. The computer arrangement of claim 73, further configured to execute 
computer-executable instructions for: 

generating a plurality of message components as a function of the fixed portion 
and the selected customized version; and 

generating an electronic mail message having the plurality of electronic mail 
addresses associated therewith. 

79. The computer arrangement of claim 77, wherein the plurality of message 
components comprises at least one of a sender electronic mail address, a recipient 
electronic mail address, a subject header, and a message body. 

80. The computer arrangement of claim 79, further configured to execute 
computer-executable instructions for, in response to identifying the recipient electronic 
mail address as a distribution list, 

determining a plurality of electronic mail addresses constituting the distribution 

list; and 
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generating a distinct electronic mail message for each of the determined electronic 
mail addresses. 

8 1 . The computer arrangement of claim 78, further configured to execute 

5 computer-executable instructions for encoding the plurality of message components using 
a MIME encoding technique. 

82. The computer arrangement of claim 78, further configured to execute 
computer-executable instructions for encoding the plurality of message components by 

10 referencing a MIME OLE library. 

83 . The computer arrangement of claim 8 1 , further configured to execute 
computer-executable instructions for: 

generating a plain text version and a rich text version of the customized 
15 document; and 

encoding the plain text and rich text versions in the electronic mail message. 

84. The computer arrangement of claim 73, further configured to execute 
computer-executable instructions for selecting an outbound server for delivering the 

20 electronic mail message according to a round-robin technique. 

85 . A computer arrangement configured to execute computer-executable 
instructions for: 

identifying a fixed portion and a variable portion of a customizable World Wide 
25 Web (WWW) page; 

isolating the variable portion of the customizable WWW page; 

storing a plurality of customized versions of the variable portion of the 
customizable WWW page in a directory hierarchy as a function of one or more 
characteristics of the customized versions; 
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in response to a request issued by a client, generating the customized WWW page 
by combining the fixed portion and the selected at least one of the plurality of customized 
versions; and 

transmitting the customized WWW page to the client. 

5 

86. The computer arrangement of claim 85, further configured to execute 
computer-executable instructions for: 

extracting a plurality of string literals from the customizable document; and 
storing the string literals as symbols. 

10 

87. The computer arrangement of claim 85, wherein the plurality of 
customized versions of the variable portion of the customizable document are stored in a 
directory hierarchy. 

15 88. The computer arrangement of claim 87, further configured to execute 

computer-executable instructions for: 

generating a plurality of encoded versions of each customized version, wherein 
the encoded versions represent DBCS, Unicode, and UTF-8 versions of a customized 
version; and 

20 storing the encoded versions in the directory hierarchy. 

89. The computer arrangement of claim 85, further configured to execute 
computer-executable instructions for receiving a client request from the client, the client 
request including a DNS entry. 

25 

90. The computer arrangement of claim 89, further configured to execute 
computer-executable instructions for: 

detecting the DNS entry; and 

selecting one of the customized versions of the variable portion as a function of 
30 the DNS entry. 
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91 . A computer arrangement configured to execute computer-executable 
instructions for: 

receiving a message type indicator, a message language indicator, and custom 
data from a client; 

receiving a message template selected as a function of the message type indicator 
and the message language indicator; 

generating a plurality of message components by combining the message template 

with the custom data; 

encoding the message components as a customized electronic mail message; and 
transmitting the customized electronic mail message to the client. 

92. The computer arrangement of claim 9 1 , wherein the custom data is 
received in a UTF-8 format, further comprising converting the custom data to a DBCS 
format before combining the custom data with the message template. 

93. The computer arrangement of claim 91, further configured to execute 
computer-executable instructions for displaying the customized electronic mail message 
before transmitting the customized electronic mail message to the client. 

94. The computer arrangement of claim 9 1 , wherein the plurality of message 
components comprises at least one of a sender electronic mail address, a recipient 
electronic mail address, a subject header, and a message body. 

95 . The computer arrangement of claim 94, further configured to execute 
computer-executable instructions for, in response to identifying the recipient electronic 
mail address as a distribution list, 

determining a plurality of electronic mail addresses constituting the distribution 

list; and 

generating a distinct electronic mail message for each of the determined electronic 
mail addresses. 
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96. The computer arrangement of claim 94, further configured to execute 
computer-executable instructions for, in response to identifying the recipient electronic 
mail address as a distribution list, 

determining a plurality of electronic mail addresses constituting the distribution 

5 list; and 

generating an electronic mail message having the plurality of electronic mail 
addresses associated therewith. 

97. The computer arrangement of claim 92, wherein the plurality of message 
1 o components are encoded using a MIME encoding technique. 

98. The computer arrangement of claim 91, further configured to execute 
computer-executable instructions for encoding the plurality of message components by 
referencing a MIME OLE library. 

15 

99. The computer arrangement of claim 98, further configured to execute 
computer-executable instructions for: 

generating a plain text version and a rich text version of a customized document; 

and 

20 encoding the plain text and rich text versions in the electronic mail message. 

1 00. The computer arrangement of claim 9 1 , further configured to execute 
computer-executable instructions for selecting an outbound server for delivering the 
electronic mail message according to a round-robin technique. 

25 

101. A computer arrangement configured to execute computer-executable 
instructions for: 

extracting a localizable portion of a localizable Internet document; 
storing localized versions of the localizable portion in a directory hierarchy; 
30 translating each localized version to a plurality of encoded versions; and 

storing the encoded versions in the directory hierarchy. 
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1 02. The computer arrangement of claim 101, wherein extracting the 
localizable portion of the localizable document comprises: 

extracting a plurality of string literals from the localizable document; and 
5 storing the string literals as symbols. 

1 03 . The computer arrangement of claim 101, wherein the encoded versions 
represent DBCS, Unicode, and UTF-8 versions of the corresponding localized version. 

10 104. A computer arrangement configured to execute computer-executable 

instructions for: 

storing a fixed portion of a localizable document and a plurality of localized 
versions of a variable portion of the localizable document; 

receiving a client request from a client, the client request including a DNS entry; 
15 detecting the DNS entry; and 

selecting one of the localized versions as a function of the DNS entry; 
generating a localized document by combining the fixed portion with the selected 
localized version; and 

delivering the localized document to the client. 
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ABSTRACT OF THE DISCLOSURE 

A method, apparatus, and software are disclosed for delivering customized 
content to clients with diverse content needs, such as clients from diverse geographical 
areas and language backgrounds. Customizable content is separated from the underlying 
code, which is used as a template for inserting localized content into a basic document 
framework as represented by the template. Both electronic mail and web community 
customization techniques are disclosed. 
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including the claims, as amended by any amendment referred to above. 

1 acknowledge the duty to disclose information which is material to the patentability of this application in 
accordance with 37 C.F.R. § 1.56 (attached hereto). I also acknowledge my duty to disclose all information known 
to be material to patentability which became available between a filing date of a prior application and the national or 
EST international filing date in the event this is a Continuation-In-Part application in accordance with 37 C.F.R. 
§|63(e). 

jijf I hereby claim foreign priority benefits under 35 U.S.C. §1 19(a)-(d) or 365(b) of any foreign application(s) 
£<?! patent or inventor's certificate, or 365(a) of any PCT international application which designated at least one 
4|pntry other than the United States of America, listed below and have also identified below any foreign application 
Jor patent or inventor's certificate having a filing date before that of the application on the basis of which priority is 
claimed: 



Hp such claim for priority is being made at this time. 

y I hereby claim the benefit under 35 U.S.C. § 1 19(e) of any United States provisional application(s) listed 
Slow: 

No such claim for priority is being made at this time. 

I hereby claim the benefit under 35 U.S.C. § 120 or 365(c) of any United States and PCT international 
application(s) listed below and, insofar as the subject matter of each of the claims of this application is not disclosed 
in the prior United States or PCT international application in the manner provided by the first paragraph of 35 U.S.C. 
§ 1 12, 1 acknowledge the duty to disclose material information as defined in 37 C.F.R. § 1 .56(a) which became 
available between the filing date of the prior application and the national or PCT international filing date of this 
application: 

No such claim for priority is being made at this time. 
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I hereby appoint the following attorney(s) and/or patent agent(s) to prosecute this application and to transact 
all business in the Patent and Trademark Office connected herewith: 



Adams, Gregory J. 


Reg. No. 


44,494 


Harris Robert J. 


Reg. No. 37,346 


Nelson Albm J. 


Reg. No. 28,650 


Anglin, J. Michael 


Reg. No. 


24,916 




Res No 42 673 


Niplsen Walter W 


Ree No 25 539 


Bianchi, Timothy E* 


Reg. No. 


39 610 


TnrVnvirh Pafti T 

J tAl rvKJ V IL-ll] 1 tULJ J. 


Reg >J 0 44 813 


Oh Allen T 


Rea No 42 047 


Billion, Richard E. 


Reg. No 


32,836 


Kalis, Janal M. 


Reg. No. 37,650 


Padys, Danny J. 


Reg No. 35,635 


Black, David W. 


Reg. No. 


42,331 


Kaufmann, John D. 


Reg. No. 24,017 


Parker, J. Kevin 


Reg. No. 33,024 


Brennan, Leoniede M.Reg. No. 35,832 




KKma-Silberg, Catherine I. 


Reg. No. 40,052 


Peacock, Gregg A. 


Reg. No. 45,001 


Brennan, Thomas F. 


Reg. No. 


35,075 


Kluth, Daniel J. 


Reg. No. 32,146 


Perdok, Monique M. 


Reg. No. 42,989 


Brooks, Edward J., Ill 


Reg. No. 


40,925 


Lacy, Rodney L. 


Reg No. 41,136 


Polglaze, Daniel J. 


Reg. No. 39,801 


Chu, Dinh CP. 


Reg No. 


41,676 


Leffert, Thomas W. 777 


Reg. No. 40,697 


Prout, William F. 


Reg. No. 33,995 


Clark, Barbara J. 


Reg. No. 


38,107 


Lemaire, Charles A. 


Reg. No. 36,198 


Sako, Katie E. 


Reg. No. 32,628 


Crouse, Daniel D. 


Reg. No. 


32,022 


Litman, Mark A 


Reg. No. 26,390 


Schumm, Sherry W. 


Reg. No. 39,422 


Dahl, John M. 


Reg. No. 


44,639 


Lundberg, Steven W. 


Reg. No. 30,568 


Schwegman, Micheal L. 


Reg. No. 25,816 


Drake, Eduardo E. 


Reg. No. 


40,594 


Mack, Lisa K. 


Reg. No. 42,825 


Shfer, Russell D. 


Reg. No 39,838 


Eliseeva, Maria M. 


Reg. No 


43,328 


Maki, Peter C. 


Reg. No. 42,832 


Smith, Michael G 


Reg No. P-45,368 


Embretson, Janet E 


Reg. No 


39,665 


Malen, Peter L. 


Reg. No. 44,894 


Steffey, Charles E. 


Reg. No. 25,179 


Fogg, David N. 


Reg. No. 


35,138 


Mates, Robert E 


Reg. No. 35,271 


Terry, Kathleen R. 


Reg. No. 31,884 


Fordenbacher, Paul J. 


Reg. No. 


42,546 


McCrackin, Ann M. 


Reg No. 42,858 


Viksnins, Ann S 


Reg. No. 37,748 


Bbgest, Bradley A. 


Reg. No. 


30,837 


Nama, Kash 


Reg. No. 44,255 


Woessner, Warren D. Reg. No. 30,440 



I h I hereby authorize them to act and rely on instructions from and communicate directly with the 

rj,#sonyassignee/attomey/firm/organization/who/which first sends/sent this case to them and by whom/which I hereby declare that I have 

consented after full disclosure to be represented unless/until I instruct Schwegman, Lundberg, Woessner & Kluth, P. A. to the contrary. 

Please direct all correspondence in this case to Schwegman, Lundberg, Woessner & Kluth, P.A. at the address indicated below; 
i'H P.O. Box 2938, Minneapolis, MN 55402 

Telephone No. (612)373-6900 

vi i I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and 
f ejjief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so 
rSfde are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false 
p|tements may jeopardize the validity of the application or any patent issued thereon. 



Mil Name of joint inventor number 1 : Scott C. Cottrille 
Citizenship: United States of America 

Post Office Address: 2261 8 NE 14th Drive 

Redmond, WA 98053 



Residence: Redmond, WA 



Signature: 



Scott C. Cottrille 




Full Name of joint inventor number 2 : Ade A, Olubummo 

Citizenship: Nigeria 

Post Office Address: 14456 108th Place NE 

Bothell,WA 98011 f\ 
,/j 

Signature: 

Ade A. Olubummo 



Residence: Bothell, WA 




Date: 



X Additional inventors are being named on separately numbered sheets, attached hereto. 
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I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and 
belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so 
made are punishable by fine or imprisonment, or both, under Section 1001 of Title 1 8 of the United States Code and that such willful false 
statements may jeopardize the validity of the application or any patent issued thereon. 



Full Name of joint inventor number 3 : Antony Halim 
Citizenship: Indonesia 
Post Office Address: 443 1 143rd Avenue SE 

Bellevue, WA 98006 



Signature: 



Residence: Bellevue, WA 




Date: 



Antony Halim 



Full Name of joint inventor number 4 : Brian R. Daugherty 
Citizenship: United States of America 

Post Office Address: 604 170th Place NE 

Bellevue, WA 98008 



Residence: Bellevue, WA 



Signature: 



Brian R. Daugherty 




Ml Name of joint inventor number 5 : Patrick Pei Cai 
(SMizenship: Peoples Republic of China 

Wit Office Address: 23901 SE 42nd Place 

W IssaquaVWA98029 

Signature: 

Patrick Pei Cai 



Residence: Issaquah, WA 




Date: 



2-2- eo 



fill Name of joint inventor number 6 : Craig Harry 
Citizenship: United States of America 

Post Office Address: 17917 NE 93rd Way, Apt. 1 

Redmond, WA 98052 



Residence: Redmond, WA 



Signature: 



Craig Harry 



J // 



Date: y 
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Attorney Docket No.: 777.327US1 

Serial No. not assigned 

Filing Date: not assigned 



§1.56 Duty to disclose information material to patentability. 



Page 4 of 4 



(a) A patent by its very nature is affected with a public interest. The public interest is best served, and the most effective patent 
examination occurs when, at the time an application is being examined, the Office is aware of and evaluates the teachings of ail information 
material to patentability. Each individual associated with the filing and prosecution of a patent application has a duty of candor and good 
faith in dealing with the Office, which includes a duty to disclose to the Office all information known to that individual to be material to 
patentability as defined in this section. The duty to disclose information exists with respect to each pending claim until the claim is canceled 
or withdrawn from consideration or the application becomes abandoned. Information material to the patentability of a claim that is 
canceled or withdrawn from consideration need not be submitted if the information is not material to the patentability of any claim 
remaining under consideration in the application. There is no duty to submit information which is not material to the patentability of any 
existing claim. The duty to disclose all information known to be material to patentability is deemed to be satisfied if all information known 
to be material to patentability of any claim issued in a patent was cited by the Office or submitted to the Office in the manner prescribed by 
§§1 .97(b)-(d) and 1 .98. However, no patent will be granted on an application in connection with which fraud on the Office was practiced 
or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. The Office encourages applicants to 
carefully examine: 

(1) prior art cited in search reports of a foreign patent office in a counterpart application, and 

(2) the closest information over which individuals associated with the filing or prosecution of a patent application believe any 
j'S pending claim patentably defines, to make sure that any material information contained therein is disclosed to the Office. 

;^(b) Under this section, information is material to patentability when it is not cumulative to information already of record or being 
iplde of record in the application, and 

(1) It establishes, by itself or in combination with other information, a prima facie case of unpatentability of a claim; or 

■ ;? - (2) It refutes, or is inconsistent with, a position the applicant takes in: 

y (i) Opposing an argument of unpatentability relied on by the Office, or 

y (ii) Asserting an argument of patentability. 

jSprima facie case of unpatentability is established when the information compels a conclusion that a claim is unpatentable under the 
ffeponderance of evidence, burden-of-proof standard, giving each term in the claim its broadest reasonable construction consistent with the 
specification, and before any consideration is given to evidence which may be submitted in an attempt to establish a contrary conclusion of 
patentability, 

(c) Individuals associated with the filing or prosecution of a patent application within the meaning of this section are: 

(1) Each inventor named in the application: 

(2) Each attorney or agent who prepares or prosecutes the application; and 

(3) Every other person who is substantively involved in the preparation or prosecution of the application and who is 
associated with the inventor, with the assignee or with anyone to whom there is an obligation to assign the application. 



(d) Individuals other than the attorney, agent or inventor may comply with this section by disclosing information to the attorney, 
agent, or inventor. 



